@import "../../themes/ionic.globals.md";

// Material Design Toggle
// --------------------------------------------------

/// @prop - Color of the active toggle
$toggle-md-active-color:                 color($colors-md, primary) !default;

/// @prop - Width of the toggle track
$toggle-md-track-width:                  36px !default;

/// @prop - Height of the toggle track
$toggle-md-track-height:                 14px !default;

/// @prop - Background color of the toggle track
$toggle-md-track-background-color-off:   $list-md-border-color !default;

/// @prop - Background color of the checked toggle track
$toggle-md-track-background-color-on:    lighten($toggle-md-active-color, 25%) !default;

/// @prop - Width of the toggle handle
$toggle-md-handle-width:                 20px !default;

/// @prop - Height of the toggle handle
$toggle-md-handle-height:                20px !default;

/// @prop - Border radius of the toggle handle
$toggle-md-handle-border-radius:         50% !default;

/// @prop - Box shadow of the toggle handle
$toggle-md-handle-box-shadow:            0 2px 2px 0 rgba(0, 0, 0, .14), 0 3px 1px -2px rgba(0, 0, 0, .2), 0 1px 5px 0 rgba(0, 0, 0, .12) !default;

/// @prop - Background color of the toggle handle
$toggle-md-handle-background-color-off:  $background-md-color !default;

/// @prop - Background color of the checked toggle handle
$toggle-md-handle-background-color-on:   $toggle-md-active-color !default;

/// @prop - Margin of the toggle
$toggle-md-media-margin:                 0 !default;

/// @prop - Transition duration of the toggle icon
$toggle-md-transition-duration:          300ms !default;

/// @prop - Opacity of the disabled toggle
$toggle-md-disabled-opacity:             .3 !default;

/// @prop - Padding of the toggle positioned on the left in an item
$toggle-md-item-left-padding:            12px 18px 12px 2px !default;

/// @prop - Padding of the toggle positioned on the right in an item
$toggle-md-item-right-padding:           12px ($item-md-padding-right / 2) 12px $item-md-padding-left !default;


// Material Design Toggle
// -----------------------------------------

.toggle-md {
  position: relative;
}


// Material Design Toggle Background Track: Unchecked
// -----------------------------------------

.toggle-md .toggle-icon {
  position: relative;
  display: block;

  width: $toggle-md-track-width;
  height: $toggle-md-track-height;

  border-radius: $toggle-md-track-height;
  background-color: $toggle-md-track-background-color-off;

  transition: background-color $toggle-md-transition-duration;

  pointer-events: none;
}


// Material Design Toggle Inner Knob: Unchecked
// -----------------------------------------

.toggle-md .toggle-inner {
  position: absolute;
  top: ($toggle-md-handle-height - $toggle-md-track-height) / -2;
  left: 0;

  width: $toggle-md-handle-width;
  height: $toggle-md-handle-height;

  border-radius: $toggle-md-handle-border-radius;
  background-color: $toggle-md-handle-background-color-off;

  box-shadow: $toggle-md-handle-box-shadow;

  transition-duration: $toggle-md-transition-duration;
  transition-property: transform, background-color;
}


// Material Design Toggle Background Track: Checked
// -----------------------------------------

.toggle-md .toggle-checked {
  background-color: $toggle-md-track-background-color-on;
}


// Material Design Toggle Inner Knob: Checked
// -----------------------------------------

.toggle-md .toggle-checked .toggle-inner {
  background-color: $toggle-md-handle-background-color-on;
  transform: translate3d($toggle-md-track-width - $toggle-md-handle-width, 0, 0);
}


// Material Design Toggle: Disabled
// -----------------------------------------

.toggle-md.toggle-disabled,
.item-md.item-toggle-disabled ion-label {
  opacity: $toggle-md-disabled-opacity;

  pointer-events: none;
}

.toggle-md.toggle-disabled ion-radio {
  opacity: $toggle-md-disabled-opacity;
}


// Material Design Toggle Within An Item
// -----------------------------------------

.item-md .toggle-md {
  margin: $toggle-md-media-margin;
  padding: $toggle-md-item-right-padding;

  cursor: pointer;
}

.item-md .toggle-md[item-left] {
  padding: $toggle-md-item-left-padding;
}

.item-md.item-toggle ion-label {
  margin-left: 0;
}


// Material Design Color Mixin
// --------------------------------------------------

@mixin toggle-theme-md($color-name, $color-base) {

  .toggle-md-#{$color-name} .toggle-checked {
    background-color: lighten($color-base, 25%);
  }

  .toggle-md-#{$color-name} .toggle-checked .toggle-inner {
    background-color: $color-base;
  }

}


// Generate Material Design Toggle Auxiliary Colors
// --------------------------------------------------

@each $color-name, $color-base, $color-contrast in get-colors($colors-md) {
  @include toggle-theme-md($color-name, $color-base);
}
